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Description 

BACKGROUND OF THE INVENTION 
5 Re!d of the Invention 

This invention relates to a portable, hand-held, device for transferring data to and from a data processing system 
via a graphical user interface, and. more particularly, to a hand-held data storage device that generates graphical user 
Input signals to facilitate data transfer. 

10 

Description of the Prior Art 

In the prior art. there are a variety of devices and networks to move data from one data processing system (e.g.. a 
personal conputer system) to another data processing system. These include diskettes (e.g., magnetic and optical). 
IS local area hardwired networks, various wireless transmission networks, and semi-conductor memory cards. 

More specifically to this invention, U.S. Patent No. 4,102.493 issued to Moreno et al. (Moreno '493) describes a 
method and apparatus for transporting data from one device to another. In Moreno '493, data is transferred from a 
processor system to a portable card in which data is electronically stored, nx)dif ied, and Uansferred to another processor 
system. Moreno '493 transports data by means of a hand-held device, but the device does not provide a user interface 
20 to facilitate the transfer (upload or download) of the data. 

U.S. Patent 4,125.871. issued November 14. 1987, to Martin et al. (Martin *871) desaibes a portable data entry 
device in which a user keys in data, which is stored in the device until a later time when the data is uploaded to a computer 
system. The portable data entry device is wholly contained within a small housing. The device includes an electronic 
memory capable of storing a plurality of multiple character records and includes manually operable controls for sequenc- 
es ing through the mernory for review and updating of previously entered data. A connector is provided on the housing by 
which the device can be directly connected to a data system for the readout of the stored data. The device is self powered 
and contains circuitry operative to conserve available energizing power, 

U.S. Patent 4.689,757, issued to Downing et al. (Downing '757). describes an apparatus for transporting information 
captured at a coin counter to a computer. The system is comprised of a discrete machine event counting module which 
30 records and stores a count of machine operation and can include means for recording the time of some selected event 
or events. The module also stores an identification code for the Particular machine. The module can be connected 
directly through a microprocessor to a central processing center, or it can be located at a machine or at a group of 
machines. The ti-ansfer unit can then be transported to access means for the central processing center and the infor- 
mation that was obtained from the module will be transferred to centers for processing and tabulation. 
35 Of course, graphical user interfaces which allow a user to generate computer commands by means of a graphical 
icon display and display pointer are well known and widely used in the art (see, for example. U.S. Patent 5.202,947 and 
the materials referenced therein). Notwithstanding, in tiie prior art there is no generally applicable, simple way to transfer 
data among diverse systems. 

40 SUMMARY OF THE INVENTION 

An object of this Invention is the provision of a hand-held, portable device to facilitate user operation in moving data 
from one computer system to another computer system or between a computer system and a stand-alone device, such 
as an automatic teller machine, a stand-alone disk storage unit, an automatic controller, or other devices witiiout a 

45 graphical user interface. 

Another object of the invention is to provide a portable hand-held device for transferring data between systems 
witiiout the need for special user input commands. 

Briefly, this invention contemplates the provision of a hand-held data storage unit which transfers data from a com- 
puter to the unit by means of a graphical user interface in the computer conti-olled by the hand-held data storage unit. 

so In a prefen-ed embodiment of the invention, a wireless communication link provides two-way communication between 
the computer and the hand-held data storage unit. The computer's graphic user interface is expanded to provide an Icon 
that transfers data to a hand-held data storage unit in response to a pointer position controlled by the hand-held data 
storage unit Data compression and/or encryption may be executed by the computer in response to an icon controlled 
by tiie hand-held unit prior to ti-ansfer and storage in the unit. 

55 A hand-held data storage unit in accordance with this invention confa-ols a CRT pointer in a similar fashion to a 
trackball or other pointing device attached to a computer system having a graphical user interface. One frequentiy used 
data manipulation operation is a so-called "cut and Paste" operation. The operation of "cut and paste" is quite useful 
and simple to use within a single system. But if a user wants to "cut" from one computer system and "paste" to another 
computer system, information has to be transferred to diskette or other portable media, or perhaps sent by LAN or WAN 
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since prior art pointer controllers, such as the mouse, trackballs, and other pointer control methods, do not have the 
ability to transport data. The invention here embodied by virtue of its portabifrty and data storage ability in combination 
with its pointer control and combined with an appropriate icon representation assodated with the graphical user interface 
permits a very simple method of 'cutting* information from one computer system and "pasting" this same information 
on another computer system. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing and other objects, aspects and advantages will be better understood from the following detailed 
description of a preferred embodiment of the invention with reference to the drawings, in which: 

Rg. 1 shows schematically an overview of the preferred embodiment and particularly shows a hand-held data 
storage device linked via wireless communication channel to a computer. 

Rg. 2 shows an exemplary view of the computer screen when the invention described herein is not linked to the 
computer. 

Rg. 3 shows an exemplary view of the computer screen when the invention described herein Is finked to the 
computer. 

Rg. 4 is a block diagram of one embodiment of the invention desaibed herein. 

Rg. 5 shows detail of certain internal logic of the embodiment of Rgure 4. 

Rg. 6 shows a block diagram of a computer interface for the preferred entjodiment. 

Rg. 7.8 are high level flow diagrams of interrupt handling structure and execution structure of the firmware associ- 
ated with a preferred emtodiment of the invention. 

DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT OF THE INVENTION 

Turning now to the invention in greater detail. Rgure 1 illustrates a preferred embodiment in which a hand-held data 
storage unit 10 is wirelessly coupled (e.g., low power electromagnetic (Vadio^ waves 14) to a computer indicated at 17. 
equipped with graphical user interface software, such as that supported by the IBM 0S2 operating system. The use of 
radio waves allows greater freedom of placement for the unit 10. thus greater freedom and ease of use for the user. 
Wireless optical communication links 1 5 and hardwired communications links 1 3 may be used also, if desired. A standard 
mouse configuration is shown, with two "clicker" buttons 11. 12 and a mouse ball assen^Iy 32. Additional buttons can 
be supported if necessary, as can additional controls. The computer 1 7 has a display screen 20 and additional hardware 
18 to communicate with hand-held data storage unit 10. In ttie preferred embodiment, hardware 18 is connected via 
serial cable 1 9 to computer 1 7. Thus, hand-held data storage unit 1 0 is (insofar as being a pointing device) similar in its 
operation to a standard serial mouse. 

Rgure.2 illustrates pictorially display screen 20 assodated with computer 17. It has a special icon 22 for supporting 
the hand-held data storage unit 10 and a universal symbol 21 to indicate when unit 10 is not in communication witii 
processor 1 7. 

Rgure 3 illustrates a typical computer screen 20 tiiat has an icon 22 supporting the hand-held data storage unit 10 
where the unit Is coupled to computer 17. State information 23 is displayed that indicates how much memory capacity 
has been used in the unit 10. Unit 10 is coupled to the computer 17 when communication between it and computer 17 
is established. If a standard mouse is attached to tiie computer, icon 22 would be displayed with an appropriate symbol, 
such as the letter "M". to signify an attached standard mouse. Alternatively, other icon images could be displayed to 
signify tiie connection of a standard mouse, 

A block diagram of tiie hand-held data transfer unit 1 0 is shown in Rgure 4. A one-chip processor indicated by the 
general reference number 30 witfi onboard CPU 37, RAM 38. program storage 40. input/out capability 39. and serial 
port 41 interfaces through logic 31 to the left mouse button 1 1 , right mouse button 12. and with the mouse ball assembly 
32. A storage unit 33 external to processor 30 and coupled thereto by bus 45 is provided to store data. Typically, with 
currentiy available components, storage unit 33 would contain about 60K bytes of SRAM. However, as storage compo- 
nent technology advances, the anticipated size of the storage unit 33 will become larger. 

In this preferred embodiment, a transceiver 34 transmits and receives radio frequency signals (indicated graphically 
at 14) coupling the unit 10 to computer 17 via interface 18. Alternative wireless coupling indicated at 15 and hard wired 
coupling indicated at 1 3 are also practicable. A serial data stream from the processor 30 via serial port 41 and connection 
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42 modulates a radio frequency carrier signal of transceiver 34. Similarly, a modulated signal received from computer 
1 7 is demodulated by circuit 34 and received as a serial data stream by processor 30 via serial port 41 . Power is provided 
by a battery 35, with due consideration of power consumption by processor 30, logic 31 , and storage 33 which should 
all be CMOS or equivalent low power logic. In addition, a processor 30 "sleep" mode is used in this preferred embodiment. 

5 The logic 31 in Rgure 4 has multiple wire connections 44 to processor 30. This logic 31 also has multiple wire 
connections 43 to mouse ball assembly 32. The logic 31 has an external inten-upt signal wire 36 to an inten*upt pin 46 
of th e processor 30. An interrupt signal on wire 36 is an event which causes processor 30 to awaken from its "sleep" mode. 

Figure 5 shows a typical implementation of logic 31. This implementation allows serial port 41 to operate at a max- 
imum practical rate. Therefore, the load on processor 30, which would be Incun-ed should processor 30 be required to 

10 poll button 11, 12 and mouse ball assembly 32 for activity, is reduced while also fadlitating the use of processor 30 
"sleep" mode. 

Figure 5 shows the logic to reduce the load on processor 30 and to reduce the power consumption of unit 10. It 
uses counters 58 and 59 coupled by leads 56 and 57 to revolution pulse generators 55 (X) and 54 (Y) coupled to a 
mouse ball 61 . Counters 58 and 59 are up/down counters, with output signals on lines 62 being emitted when the counter 

15 is in a non-zero state. These counters keep track of mouse ball 61 movement even while processor 30 is busy with other 
tasks. Reading counters 58 or 59 via a bus 53 results in the respective counters being reset to a zero state. Read, chip 
select, and addressing signals are represented by wires 52. which are a subset of wires 44. Logic circuit 60 debounces 
and detects a state change of button 1 1 and button 12; a state change for either button results in a signal on line 63 
being emitted. This signal 63 is combined via logic 64 with signals 62 emitted by counter 58 and 59. The resulting signal 

20 emitted by logic 64 is applied to wire 36 as an interrupt to processor 30. The debounced change of state of buttons 1 1 
and 12 are also outputted on leads 50 and 51. 

Figure 6 is a block diagram of the interface module 18. In transmitting data to the unit 10 from the computer 1 7. a 
serial data stream received via serial cable 19 modulates a radio frequency canier generated by an oscillator 82. An rf 
link 81 couples the modulated can-ier signal to a transceiver 80 which transmits the signal to the unit 10. In transmitting 

25 date from the unit 10 to the computer 17, the signal received from unit 10 is demodulated by transceiver 80 and the 
demodulated serial data stream Is sent to computer 17 via serial cable 19. Power for the transceiver 80 is taken from 
the serial cable 19, as only a very low power output radio frequency signal is desired or required. 

An example of a command set for the hand-held data transfer unit 1 0 is: 
DIREGTORY-provides a list of the data currently preserved in Data Mouse and the free space available. By implication, 

30 ■ 
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this also provides the size of the Data Mouse total memory. 

Name/location/size/chain/ . . . /name/location/slze/chain/ 
freesize/EOF 

Return codes: 

•command successful 
•command not understood 
•storage error 

COPY <DM->C> or <C->DM> 

Command to copy data to the portable device 10 or copy data 
from the portable device 10 

Return codes: 

•command successful 
•command not understood 
•storage error 

•insufficient space, command not done 

ERASE <name> 

(note: degenerate form of copy — copy over a name with 
length 0) 

Return codes: 

•command successful 
•command not understood 
•storage error 

•insufficient space, command not done 



FORMAT 

Clear the data stored in portable device 10 

Note that the GUI support should inquire "Are You Sure" . 
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Return codes: 



•command successful 



•command not understood 



•storage error 



DIAG <mode<,subcommand>> 

Execute diagnostics, two modes, one clears memory and one 
does not, with subcommands 



Return 



codes : 



•command 



successful 



•command 



not understood 



•storage error 

•processor ROM checksum failure 
•processor RAM checksum failure 
•other logic error (actually, several) 



ACTION <SQUEEK5BLINK3TWITCH> 

(optional, based on capability of DM, preferred embodiment 
does not show the hardware to support this capability) 
Return codes: 



Rgures 7 and 8 are high level flow charts for certain of the operations of processor 30. The firmware to carry out these 
operations is coded in permanent storage element 40 (ROM). 

Figure 7 is the intemjpt handling micro code flow. An interrupt, either IRQ 46 or from the serial port 41 . initiates 
interrupt handling. Decision 1 1 0 determines if the event is a change of state of buttons 11 or1 2; this is done by examining . 
information received via 1/0 port 39 in particular, the lines from logic 44 as compared with the preserved last state of 
the buttons as preserved in processor RAM 38 of processor 30. If the event is a change of state of one of the buttons 
11 or 1 2, further processing is done by finalizing the debounce of the buttons as shown by block 111. verifying continued 
presence in block 1 12. and, if the change of state is confirmed, making the appropriate state variable changes as indi- 
cated by block 1 1 3. If the event was not a change of state of a button or the change of state of a button or buttons has 
been handled, then control is passed to a decision block 120 to determine if there has been movement of the mouse 
bail 61 . If so, the appropriate information is gathered and states changes as shown by block 121 . If the preceding blocks 
have completed, a check is made at block 130 to see if serial port 41 has generated an interrupt indicating the completion 
of transmission or reception of data. If so. the data is collected Qi data is being recaved) or, if necessary, additional data 
is written to the serial port (if transmission) as represented by block 131. After completing the aforementioned, interrupt 
handling is completed and the routine exits as shown by block 140. The state information generated by blocks 1 13. 121 
and 131 is used by the general execution code to manipulate data or modify hardware as necessary. 

Note that the descn'ption of interrupt handling is from a very high level and minor details not necessary to elucidate 
operation are not shown-for example, the preservation of registers upon entry to the interrupt handling routine, and a 
check for additional pending inten'upts prior to exit via block 1 40 among other details. 



« command successful 



•command not understood 
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Of particular interest is the use of the interrupt to awaken from power conserving 'sleep' mode. Referring now to 
Figure 8. the hand-held data storage unit 10. when not linked to a computing system or other device, would reside in 
"sleep" mode as represented at 201 . An interrupt, as desaibed in connection with Figure 7. awakens processor 30 from 
its "sleep" mode. After processor 30 completes handling the interrupt (block 202), processor 30 initiates an action to 

5 ched< for a link to computer 1 7 (for example, at block 200). If no such link is present, processor 30 returns to its sleep 
mode of operation (block 201 ). If there is a link connection to the computing system, processor 30 replies to the computing 
system request with "I'm alive" status (block 110). Next in block 220. the processor 30 checks to see if any action is to 
be taken. Actions would be represented by changes to state variables as might be done by blocks 113. 121. 131 of 
Rgure 7, including the reception of an external request (via serial port 41, represented in Figure 7 by block 131). The 

10 processor 30 handles any rquired action at block 230. If there is action is to be taken, there was possibly an error on 
the link. 

While the invention has been described in terms of a single preferred embodiment, those skilled in the art will 
recognize that the invention can be practiced with modification v/ithin the spirit and scope of the appended 

15 Claims 

1 , A portable hand-held data storage unit for transferring data to and from a computer system that performs operations 
in response to inputs generated by graphical user interface, said data storage unit comprising in combination: 
a microprocessor; 
20 a solid-state memory for storing data; 

means operatively coupling said solid-state memory and said microprocessor; 
a communications port operatively connected to said microprocessor; 

a manually operable, graphical user interface control signal generating means whose output is coupled to said 
microprocessor; 

25 said microprocessor transmitting graphical user interface control signals to said computer system via said commu- 
nications port in response to an output from said manually operable, graphical user interface control signal generating 
means, whereby a user can command the transfer of data from said computer system to said solid-state memory 
by means of said graphical user interface. 

30 2. A method for transferring data from one computer system, which performs operations in response to inputs gener- 
ated by a graphical user interface, to another system, comprising the steps of: 
generating graphical user interface command signals in a hand-held, portable digital data storage unit; 
transmitting said command signals from said hand-held, portable digital data storage unit to said computer system; 
moving a pointer on a display screen in response to the transmitted command signal in order to transmit said data 

35 to said hand-hekJ, portable digital data storage unit; 

transmitting said data from said one computer system to said hand-hekJ, portable digital data storage unit; 

storing said data transmitted in the just previous storage step in said hand-held, portable digital data storage unit; and 

transmitting said data stored in said storing step to said another system. 

40 3. A portable hand-held data storage unit as in claim 1 wherein said communications port includes a wireless trans- 
ceiver. 

4, A portable hand-held data storage unit as in claim 1 further including a battery for powering said unit. 

45 5. A portable hand-held data storage unit as in daim 1 wherein said manually operable, graphical user interface control 
signal generating means includes a rotatable member and counter means to store incremental rotation of said 
member. 

6. A portable hand-held data storage unit as in claim 4 wherein said microprocessor transfers between a normal oper- 
50 ating mode in response to operational inputs and a low power operating nxxle in the absence of said operational 

inputs. 

7. A portable hand-held data storage unit as in claim 5 wherein said microprocessor transfers between a normal oper- 
ating mode in response to operational inputs and a low power operating mode in the absence of said operational 

55 inputs. 



7 



EP0703 544 A1 




8 



EP0 703 544A1 




nG.2 



FIG.3 



EP0703544A1 



11 



12 



36 




nG.4 



10 



EP0703544A1 




11 



EP0703 544A1 



14-^ 1 




■18 




81 



82 



r 



19 



FIG.6 



46 



IRQ 



110 



BUTTON? 
N 



120 



BALL? 
N 



130 



SERIAL? 
N 



140 
^EXIT 



SERIALEVENT 



41 



•111 
DEBOUNCE - 



112 



STILL PRESENT?-^ 
CHANGE STATE 



-COLLECT DATA ^121 
CHANGE STATE 



-COLLECT DATA^131 
CHANGE STATE 



FIG.7 



12 



EP0703544A1 



200 
^ LINK? 
Y 

210 



V,. 



220 
230 

c 



M ALIVE?- 
N 

ACTION? 
Y 



Y 



N 



-201 
WAI (SLEEP) - 



•202 
XMIT FOR LINK 



^221 
ERROR - 



HANDLE ACTION 



FIG.8 



13 



EP0703 544A1 




European Patent 
Oflice 



EUROPEAN SEARCH REPORT 



AppGatiQo Noaber 

EP 95 11 2397 



DOCUMENTS CONSIDERED TO BE RELEVANT 



CkaCioa of document mth Indication, where approfiriate, 
of rck»ant pMages 



Relevant 
Co daim 



CLASSinCATION OF THE 
APPUCATION (IitCU) 



IBM TECHNICAL DISCLOSURE BULLETIN, 
vol. 37, no.. 07, July 1994 NEW YORK 
pages 1-2, 'Memory mouse' 
* the whole document * 



US, 



EP-A-0 171 747 (METAPHOR COMPUTER SYSTEMS) 

* abstract * 

* page 9, line 30 - page 10, Une 2; 
figure 2 * 

* page 12, line 34 - page 13, line 6 * 

* page 21, line 9 - page 22, line 24; 
figure 4 * 

* page 23, line 9 - line 22 * 

CHIP ZEITSCHRIFT FUER 
MIKROCOMPUTER-TECHNIK, 
no. 07, July 1991 WURZBURG DE. 
pages 52-55, 'Vora Kabel befreit ..." 

* page 53, column 2, line 7 - column 3, 
line 29 *. 



1-7 



1.3-7 



G06K11/18 



1,3-7 



TECHNICAL HCLOS 
SEARCHEO (lAta.6} 



G06K 



The prcscaC scardi report has hccn drawn up for all daims 



Flwi tf Mvck 

THE HAGUE 



1 December 1995 



Bravo, P 



CATEGORY OF CUED DOCUMENTS 

X : pirtlailtfly rdcvur If tiica tloae . 

V : paKleuUrty rdcvut If ansbtacl with mother 

doctmeot ot the sane catefory 
A : tedinoloflcal bsckcnHiA4 
O : aaa-«rtttcn rilxdot ttr« 
P : latcmcdlat* document 



T : theory or priadplt ttftdcrlytoc the bvctitfoo 
E : evUcr patent document, bat published ob« or 

tftcr the fUtas date 
D : document dted Id the ippllcatioa 
L : docameat dted for other reasons 

A : member of the nnc patent fuolly, corrcxpoadlng 
docuncot 



14 



This Paee is Inserted by IFW Indexing md Scannuig 
OpSL and is J part of the Official Record 

BEST AVAILABLE IMAGES 

Defective images within tins docmnent are accurate «pre.eB»ti.«8 of the oripnal 

documents submitted by the appHcant. 

Defects itv the images include but are not litnited to the items checked, 

□ black BORDERS 

□ IMAGE CUT OFF AT TOP, BOTTOM OR SIDES 

□ FADED TEXT OR DRAWING 

□ BLURRED OR ILLEGIBLE TEXT OR DRAWING 

□ SKEWED/SLANTED IMAGES - , 

□ COLOR OR BLACK AND WHITE PHOTOGRAPHS 

□ GRAY SCALE DOCinVIENTS 

□ LINES OR MARKS ON ORIGINAL DOCUMENT 

□ REFERENCE(S)OREXHIBrr(S)SUBMmED ARE POOR QUALITY 

□ OTHER: " 



IMAGES ARE BEST AVAILABl* COPY, 
As rescanning these documents will not, con — . 
problems checked, please do not report these problems to 
the IFW Image Problem Mailbox. 



